Skip to content
0

Git - 基本原理

NOTE

简单了解 Git 的基本原理和哈希算法。

2022-02-08 @Young Kbt

哈希法

image-20220208210345146

哈希是一个系列的加密算法,各个不同的哈希算法虽然加密强度不同,但是有以下几个共同点:

  • 不管输入数据的数据量有多大,输入同一个哈希算法,得到的加密结果长度固定。

  • 哈希算法确定,输入数据确定,输出数据能够保证不变

  • 哈希算法确定,输入数据有变化,输出数据一定有变化,而且通常变化很大

  • 哈希算法不可逆

Git 底层采用的是 SHA-1 算法。

哈希算法可以被用来验证文件。原理如下图所示:

image-20220208210440600

Git 就是靠这种机制来从根本上保证数据完整性的。

Git 保存版本的机制

集中式版本控制工具的文件管理机制

以文件变更列表的方式存储信息。这类系统将它们保存的信息看作是一组基本 文件和每个文件随时间逐步累积的差异。

image-20220208210531433

Git 文件管理机制

Git 把数据看作是小型文件系统的一组快照。每次提交更新时 Git 都会对当前的全部文件制作一个快照并保存这个快照的索引。为了高效,如果文件没有修改,Git 不再重新存储该文件,而是只保留一个链接指向之前存储的文件。所以 Git 的工作方式可以称之为快照流。

image-20220208210627089

Git 文件管理机制细节

Git 的「提交对象」(每个文件对应的 hash 值)

image-20220208210705167

提交对象及其父对象形成的链条

image-20220208210727373

Git 分支管理机制

分支的创建

新建一个指针

image-20220208210803173

分支的切换

HEAD 指向

image-20220208210813810

HEAD 指向 testing 时提交了内容

image-20220208210906444

切换回 master

image-20220208210915284

HEAD 指向 master 时 提交了数据

image-20220208210925287

最近更新